Attorney Docket: 042390.P11188 



CLAIMS 



What is claimed is: 

11. A method for extending a hidden execution and storage mode of a processor 

2 in a computer system, comprising: 

3 providing a mechanism to enable a loading of an event handler that is not 

4 stored in an original set of firmware as supplied by an original equipment 

5 manufacture (OEM) of the computer system into a hidden memory space that is 

6 accessible to the hidden execution and storage mode but is not accessible to other 

7 operating modes of the processor; and 

8 executing the event handler in response to an event that causes the 

9 processor to be switched to the hidden execution and storage mode to service the 
10 event. 

1 2. The method of claim 1 , wherein the hidden execution and storage mode 

2 comprises a System Management Mode (SMM) of a microprocessor. 

1 3. The method of claim 1 , wherein the mechanism for enabling loading and 

2 execution of the event handler comprises: 

3 providing an abstracted interface that enables a set of machine code 

4 corresponding to an event handler that is stored outside of any component(s) in 

5 which the original set of firmware is stored to be loaded into the hidden memory 

6 space; 

7 redirecting an instruction pointer for the processor to execute the set of 

8 machine code to service the event while the processor is operating in the hidden 

9 execution and storage mode. 
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1 4. The method of claim 3, wherein the abstracted interface is published during a 

2 pre-boot process for the computer system to enable a driver to load the set of 

3 machine code corresponding to the event handler prior to loading an operating 

4 system for the computer system. 

1 5. The method of claim 1 , wherein the mechanism for enabling loading of the 

2 event handler comprises: 

3 scanning for any firmware volumes that are materialized during a pre-boot 

4 process for the computer system to identify an existence of any firmware file 

5 containing an event handler that is compatible with the hidden execution and 

6 storage mode of the processor; 

7 loading the event handler into the hidden memory space; 

8 redirecting an instruction pointer for the processor to execute the event 

9 handler to service the event while the processor is operating in the hidden execution 
10 and storage mode. 

1 6. The method of claim 1 , further comprising: 

2 loading an event handler management service into the hidden memory 

3 storage space; 

4 registering one or more event handlers with the event handling management 

5 service; 

6 loading said one or more event handlers into the hidden memory space; 

7 redirecting an instruction pointer for the processor to begin execution of the 

8 event handler management service is response to the event that causes the 

9 processor to be switched to the hidden execution and storage mode; and 
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10 dispatching an event handler via the event handler management service to 

1 1 service the event. 

1 7. The method of claim 6, wherein a plurality of event handlers are registered 

2 with the event handling management service and loaded into the hidden memory 

3 space, further comprising: 

4 creating an ordered list of said plurality of event handlers; 

5 dispatching a first event handler; 

6 determining if the first event handler is an appropriate event handler for 

7 servicing the event and, if it is, executing the first event handler to completion to 

8 service the event; otherwise 

9 dispatching a next event handler in the list and determining whether that 

10 event handler is an appropriate event handler and repeating this function until the 

1 1 appropriate event handler has been dispatched, whereupon that event handler is 

12 executed to completion to service the event. 

1 8. A method for claim 7, wherein each of said plurality of event handlers 

2 comprise a set a machine code that is executed by the processor to service an error 

3 condition generated by a hardware component in the computer system that causes 

4 the event, and determining whether arkevent handler is the appropriate event 

5 handler for servicing the event comprises^ 

6 executing a first portion of the set oKmachine code corresponding to the 

7 event handler that was most recently dispatched that queries the hardware 

8 component corresponding to that event handleMo determine if the error condition 

9 was caused by that hardware component; and \ 

10 completing execution of the set of machine cbde for the event handler if it is 

1 1 determined that the error condition was cause by its corresponding hardware 
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12 component, otherwise returning a value to the event handler management service 

13 indicating that the event handler is not the appropriate event handler to service the 

14 error condition. 

1 9. The method of claim 6, further comprising authenticating the event handler 

2 before it is loaded into the hidden memory space. 

1 10. The method of claim 6, wherein the original set of firmware includes one or 

2 more legacy event handlers, further comprising: 

3 registering said one or more legacy event handlers with the event handling 

4 management service; 

5 loading said one or more legacy event handlers into the hidden memory 

6 space accessible to the hidden execution and storage mode; and 

7 dispatching at least one of said one or more legacy event handlers via the 

8 event handler management service to service the event. 

1 11. The method of claim 6, wherein the computer system includes a plurality of 

2 processors, further comprising: 



3 loading the service handler management service into a selected processor 

4 among said plurality of processors; 

5 causing the selected processor to begin execution of the service handler 

6 management service in response to the event; 

7 synchronizing all of said plurality of processors other than the selected 

8 processor and halting execution of a respective current operation for each of these 

9 other processors during execution of the service handler management service; 
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10 returning all of said plurality of processors to a previous processing mode to 

1 1 resume execution of their respective operations after the event has been serviced 

12 by an appropriate event handler. 

1 1 2. The method of claim 1 , further comprising enabling any legacy event 

2 handlers that are stored as machine code in the original set of firmware to be 

3 executed to service the event, as appropriate, in response to the event. 

1 13. A method for extending a System Management Mode (SMM) of a 

2 microprocessor in a computer system, comprising: 

3 publishing an interface during a pre-boot process for the computer system to 

4 enable a driver that is stored outside of components in which the original set of 

5 firmware is stored to provide a set of machine code comprising an event handler 

6 that is loaded into SMM memory (SMRAM) that is accessible to the microprocessor 

7 while in SMM; 

8 switching the microprocessor to SMM in response to an SMM triggering 

9 event; and 

10 executing the event handler to service the SMM triggering event. 

1 14. The method of claim 13, further comprising: 

2 loading an event handler management service into SMRAM; 

3 registering one or more event handlers with the event handling management 

4 service; 

5 loading said one or more event handlers into SMRAM; 

6 redirecting an instruction pointer for the microprocessor to begin execution of 

7 the event handler management service is response to the SMM triggering event; 

8 and 
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dispatching an event handler via the event handler management service to 
service the event. 



1 15. The method of claim 14, wherein a plurality of event handlers are registered 

2 with the event handling management service and loaded into SMRAM, further 

3 comprising: 

4 creating an ordered list of said plurality of event handlers; 

5 dispatching a first event handler; 

6 determining if the first event handler is an appropriate event handler for 

7 servicing the SMM triggering event and, if it is, executing the first event handler to 

8 completion to service the event; otherwise 

9 dispatching a next event handler in the list and determining whether that 

10 event handler is an appropriate event handler for servicing the SMM triggering event 

1 1 and repeating this function until the appropriate event handler has been dispatched, 

12 whereupon that event handler is executed to completion to service the SMM 

13 triggering event. 

16. The method of claim\4, further comprising authenticating the event handler 

2 before it is loaded into SRMAM. 

1 17. The method of claim 14, wherein the original set of firmware includes one or 

2 more legacy event handlers, further comprising: 

3 registering said one or more legacy event handlers with the event handling 

4 management service; 

5 loading said one or more legacy event handlers into SMRAM; and 
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6 dispatching at least one of said one or more legacy event handlers via the 

7 event handler management service to service a legacy event corresponding to the 

8 SMM triggering event. 

1 18. The method of claim 1 3, further comprising: 

2 scanning for any firmware volumes that are materialized during the pre-boot 

3 process for the computer system to identify an existence of any firmware file 

4 containing an event handler that is compatible with the SMM mode of the 

5 microprocessor; 

6 loading the event handler into SMRAM; and 

7 executing the event handler to service the SMM triggering event. 

1 19. A method for handling a Platform Management Interrupt (PMI) event in a 

2 processor, comprising: 

3 loading a PMI event-handling management service into memory accessible to 

4 the processor; 

5 registering an entry point for the PMI event-handling management service; 

6 enabling one or more PMI event handlers to be made accessible to the 

7 processor via the PMI event-handling management service; and 

8 in response to the PMI event, vectoring the processor to begin executing the 

9 PMI event-handling management service at its entry point, wherein execution of the 

10 PMI event-handling management service performs the function of: 

1 1 dispatching at least one of said one or more PMI event handlers to service 

12 the PMI event. 

1 20. The method of claim 19, wherein the said one or more PMI event handlers 

2 are made accessible to the PMI event-handling management service by publishing a 
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registration interface that enables registration of PMI event handlers with the PMI 
event-handling management service. 



1 21 . The method of claim 20, wherein a plurality of event handlers are registered 

2 with the PMI event handling management service, further comprising: 

3 creating an ordered list of said plurality of event handlers; 

4 dispatching a first event handler; 

5 determining if the first event handler is an appropriate event handler for 

6 servicing the PMI event and, if it is, executing the first event handler to completion to 

7 service the event; otherwise 

8 dispatching a next event handler in the list and determining whether that 

9 event handler is an appropriate event handler for servicing the PMI event and 

10 repeating this function until the appropriate event handler has been dispatched, 

1 1 whereupon that event handler is executed to completion to service the PMI event. 



1 22. The method of claim 1 9, wherein the computer system includes a plurality of 

2 processors, further comprising: 



3 loading the PMI event handler management service into a selected processor 

4 among said plurality of processors; 

5 causing the selected processor to begin execution of the PMI event handler 

6 management service in response to the event; 

7 synchronizing all of said plurality of processors other than the selected 

8 processor and halting execution of a respective current operation for each of these 

9 other processors during execution of the service handler management service; 

10 returning all of said plurality of processors to a previous processing mode to 

1 1 resume execution of their respective operations after the PMI event has been 

12 serviced by an appropriate event handler. 
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1 23. A machine-readable medium having a plurality of machine instructions stored 

2 thereon that when executed by a processor in a computer system performs the 

3 operations of: 

4 providing a mechanism to enable a loading of an event handler that is not 

5 stored in an original set of firmware as supplied by an original equipment 

6 manufacture (OEM) of the computer system into a hidden memory space that is 

7 accessible to a hidden execution and storage mode of the processor but is not 

8 accessible to other operating modes of the processor; and 

9 executing the event handler in response to an event that causes the 

10 processor to be switched to the hidden execution and storage mode to service the 

1 1 event. 

1 24. The machine-readable medium of claim 23, wherein the mechanism for 

2 enabling loading and execution of the event handler comprises: 



3 providing an abstracted interface that enables a set of machine code 

4 corresponding to an event handler that is stored outside of any component(s) in 

5 which the original set of firmware is stored to be loaded into the hidden memory 

6 space; 

7 redirecting an instruction pointer for the processor to execute the set of 

8 machine code to service the event while the processor is operating in the hidden 

9 execution and storage mode. 



1 25. The machine-readable medium of claim 23, wherein the mechanism for 

2 enabling loading and execution of the event handler comprises: 

3 scanning for any firmware volumes that are materialized during a pre-boot 

4 process for the computer system to identify an existence of any firmware file 
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5 containing an event handler that is compatible with the hidden execution and 

6 storage mode of the processor; 

7 loading the event handler into the hidden memory space; 

8 redirecting an instruction pointer for the processor to execute the event 

9 handler to service the event while the processor is operating in the hidden execution 
10 and storage mode. 

1 26. The machine-readable medium of claim 23, wherein execution of said 

2 plurality of machine instructions further performs the operations of: 

3 loading an event handler management service into the hidden memory 

4 space; 

5 registering one or more event handlers with the event handling management 

6 service; 

7 loading said one or more event handlers into the hidden memory space; 

8 redirecting an instruction pointer for the processor to begin execution of the 

9 event handler management service is response to the event that causes the 

10 processor to be switched to the hidden execution and storage mode; and 

1 1 dispatching an event handler via the event handler management service to 

12 service the event. 

1 27. The machine-readable medium of claim 26, wherein a plurality of event 

2 handlers are registered with the event handling management service and loaded 

3 into the hidden memory space, and execution of said plurality of machine 

4 instructions further performs the operations of: 

5 creating an ordered list of said plurality of event handlers; 

6 dispatching a first event handler; 
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7 determining if the first event handler is an appropriate event handler for 

8 servicing the event and, if it is, executing the first event handler to completion to 

9 service the event; otherwise 

10 dispatching a next event handler in the list and determining whether that 

1 1 event handler is an appropriate event handler and repeating this function until the 

12 appropriate event handler has been dispatched, whereupon that event handler is 

13 executed to completion to service the event. 



1 28. A computer system comprising: 



2 a motherboard on which an original set of firmware is stored; 

3 a memory operatively coupled to the motherboard in which a plurality of 

4 machine instructions are stored; and 

5 a processor linked in communication with the memory, for executing the 

6 machine instructions to perform the operations of: 

7 providing a mechanism to enable a loading of an event handler that is not 



8 stored in an original set of firmware as supplied by an original equipment 

9 manufacture (OEM) of the computer system into a hidden memory space that is 

10 accessible to a hidden execution and storage mode of the processor but is not 

1 1 accessible to other operating modes of the processor; and 

12 executing the event handler in response to an event that causes the 

13 processor to be switched to the hidden execution and storage mode to service the 
1 14 event. 

1 29. The computer system of claim 28, wherein the mechanism for enabling 

2 loading and execution of the event handler comprises: 

3 providing an abstracted interface that enables a set of machine code 

4 corresponding to an event handler that is stored outside of any component(s) in 
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5 which the original set of firmware is stored to be loaded into the hidden memory 

6 space; 

7 redirecting an instruction pointer for the processor to execute the set of 

8 machine code to service the event while the processor is operating in the hidden 

9 execution and storage mode. 

1 30. The computer system of claim 28, wherein the mechanism for enabling 

2 loading and execution of the event handler comprises: 

3 scanning for any firmware volumes that are materialized during a pre-boot 

4 process for the computer system to identify an existence of any firmware file 

5 containing an event handler that is compatible with the hidden execution and 

6 storage mode of the processor; 

7 loading the event handler into the hidden memory space; 

8 redirecting an instruction pointer for the processor to execute the event 

9 handler to service the event while the processor is operating in the hidden execution 
10 and storage mode. 
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